# Cache Organization And Access Patterns

# Problem 1

The following table gives the parameters for a number of different caches, where m is the number of physical address bits, C is the cache size (number of data bytes), B is the block size in bytes, and E is the number of lines per set. For each cache, determine the number of cache sets (S), tag bits (t), set index bits (s), and block offset bits (b).

| Cache | m  | C    | В  | E   | S | t | s | b |
|-------|----|------|----|-----|---|---|---|---|
| 1.    | 32 | 1024 | 4  | 4   |   |   |   |   |
| 2.    | 32 | 1024 | 4  | 256 |   |   |   |   |
| 3.    | 32 | 1024 | 8  | 1   |   |   |   |   |
| 4.    | 32 | 1024 | 8  | 128 |   |   |   |   |
| 5.    | 32 | 1024 | 32 | 1   |   |   |   |   |
| 6.    | 32 | 1024 | 32 | 4   |   |   |   |   |

### **Problem2**

The following problem concerns basic cache lookups.

- The memory is byte addressable.
- Memory accesses are to **1-byte words** (not 4-byte words).
- Physical addresses are 13 bits wide.
- The cache is 2-way set associative, with a 4 byte line size and 16 total lines.

In the following tables, all numbers are given in hexadecimal. The contents of the cache are as follows:

|       | 2-way Set Associative Cache |       |        |        |        |        |     |       |        |        |        |        |
|-------|-----------------------------|-------|--------|--------|--------|--------|-----|-------|--------|--------|--------|--------|
| Index | Tag                         | Valid | Byte 0 | Byte 1 | Byte 2 | Byte 3 | Tag | Valid | Byte 0 | Byte 1 | Byte 2 | Byte 3 |
| 0     | 09                          | 1     | 86     | 30     | 3F     | 10     | 00  | 0     | 99     | 04     | 03     | 48     |
| 1     | 45                          | 1     | 60     | 4F     | E0     | 23     | 38  | 1     | 00     | BC     | 0B     | 37     |
| 2     | ЕВ                          | 0     | 2F     | 81     | FD     | 09     | 0B  | 0     | 8F     | E2     | 05     | BD     |
| 3     | 06                          | 0     | 3D     | 94     | 9B     | F7     | 32  | 1     | 12     | 08     | 7B     | AD     |
| 4     | C7                          | 1     | 06     | 78     | 07     | C5     | 05  | 1     | 40     | 67     | C2     | 3B     |
| 5     | 71                          | 1     | 0В     | DE     | 18     | 4B     | 6E  | 0     | В0     | 39     | D3     | F7     |
| 6     | 91                          | 1     | A0     | В7     | 26     | 2D     | F0  | 0     | 0C     | 71     | 40     | 10     |
| 7     | 46                          | 0     | B1     | 0A     | 32     | 0F     | DE  | 1     | 12     | C0     | 88     | 37     |

### Part 1

The box below shows the format of a physical address. Indicate (by labeling the diagram) the fields that would be used to determine the following:

- CO The block offset within the cache line
- CI The cache index
- CT The cache tag

|   | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|---|----|----|----|---|---|---|---|---|---|---|---|---|---|
| ſ |    |    |    |   |   |   |   |   |   |   |   |   |   |
|   |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Į |    |    |    |   |   |   |   |   |   |   |   |   |   |

### Part 2

For the given physical address, indicate the cache entry accessed and the cache byte value returned **in hex**. Indicate whether a cache miss occurs.

If there is a cache miss, enter "-" (a dash) for "Cache Byte returned".

Physical address: 0E34

A. Physical address format (one bit per box)

|  | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|--|----|----|----|---|---|---|---|---|---|---|---|---|---|
|  |    |    |    |   |   |   |   |   |   |   |   |   |   |
|  |    |    |    |   |   |   |   |   |   |   |   |   |   |

#### B. Physical memory reference

| Parameter           | Value |
|---------------------|-------|
| Byte offset         | 0x    |
| Cache Index         | 0x    |
| Cache Tag           | 0x    |
| Cache Hit? (Y/N)    |       |
| Cache Byte returned | 0x    |